草庐IT

c++ - RAII 和 C++ STL

全部标签

c++ - 如何使用 STL 算法找到分隔字符串中两个不同字母的最短星号序列?

我有这样一个字符串:A*A**B***A**我对两个不同字母之间的星号序列感兴趣,特别是我需要找到最短的此类序列的长度。对于上面的字符串,答案当然是2:A**B我可以使用我习惯的传统循环轻松解决这个问题:conststrings="A*A**B***A**";string::size_typelast_letter=-1,min_seq_len=s.size();for(inti=0;i但是,有没有办法使用C++来做到这一点algorithmslibrary、迭代器等?我问这个问题是因为我注意到我在学习如何使用这些工具来解决算法问题时遇到了困难,相反我发现手动编写循环更容易。我想最终学

c++ - 如何使用STL获取系统的小数分隔符?

要使用正确的数字分隔符('.'或',')生成csv文件,因为我希望它们与机器上安装的Excel版本兼容,我需要从C++程序中获取小数点分隔符。我的机器有法语版的Windows/Excel,所以小数点分隔符是','。intmain(){std::cout>(std::cout.getloc()).decimal_point();return0;}输出.,这不是预期的我尝试使用WIN32API:intmain(){TCHARszSep[8];GetLocaleInfo(LOCALE_USER_DEFAULT,LOCALE_SDECIMAL,szSep,8);std::cout输出,,这是预

c++ - 并发空间上很酷的开源项目?

我正在C和C++并发编程空间中寻找很酷的开源项目,这些项目需要积极的开发人员贡献。我是领域中立的,但会更喜欢数学/统计相关领域的东西。任何提醒的人? 最佳答案 提升C++库集合我建议看一下boostC++librarycollection.有几个处理并发处理的有趣库,使用这些库将极大地提高您自己的通用和跨平台C++编程技能。他们的一些libraries与并发有关。boost的好处在于它分布广泛,并且是C++0x对C++标准的更新中出现的许多变化的源头,因此每一个贡献都会产生巨大的影响。接受的并发库-Boost.Interproces

c++ - Eclipse[HELIOS] CDT : Autocomplete, STL 不能与 Eclipse 一起工作..帮助!

我是一个java用户,但想玩弄CPP,所以我为eclipse[HELIOS]安装了CDT插件。我在尝试正确配置它时遇到了一些问题,想知道是否有人可以帮助我。这是我们可以使用的简短代码:#include"Base.h"//Theselinesgiveerror=>Unresolvedinclusion:#include#includeusingnamespacestd;voidBase::ininitalizeVector(){for(inti=0;i1]自动完成功能不适用于STL。2]在我点击点“。”后,我无法获得支持的方法列表等。3]包含不起作用:#include4]我认为使用命名空

c++ - 与 STL vector 对齐分配

我希望我的vector存储对齐(比如16字节边界),所以我将这个分配器作为memalign()的包装器,我想知道这是否是正确的方法分配用于STLvector的对齐内存。templateclassAlignedAllocator{public:...pointerallocate(size_typesize,const_pointer*hint=0){return(pointer)memalign(Alignment,size*sizeof(T));};voiddeallocate(pointerp,size_typesize){free(p);};...}如果没有,是否有适用于STL容

c++ - 如何将 STL 映射保存到文件 C++

我正在尝试使用map将数据安全地保存到文件中,但我不知道如何操作。我想将学生的姓名和年龄保存到文件中,然后当我查找学生的姓名时,它应该显示他们的年龄。#include#include#include#includeusingnamespacestd;classstudent{private:mapmap;public:voidstudents(stringname,intage);};voidstudents(stringname,intage){if(age>name;cout>age;//codetosavemaptofilefilemap.close();}

c++ - 多维稀疏矩阵压缩

任何人都可以推荐一个好的C++库来存储多维稀疏矩阵,它专注于矩阵中数据的压缩。矩阵的维数会很大(比如80维)。欢迎任何帮助:)。编辑:矩阵高度稀疏,数量级为0.0000001(或)1x10-6。 最佳答案 在c#中,我使用键值对或“字典”来存储稀疏填充数组。我认为对于80个维度,您必须构建一个基于字符串的键。使用单个函数来创建它应该保持一致的key。只需连接一个逗号分隔的维度列表。不幸的是,我不知道一个好的key对,C++的字典库。如果您以前使用过,可能是STL,但我不会推荐它。 关于c

c++ - 具有不同包含类型的 STL 容器?

假设我有不同类型的结构组件。也许我有TransformComponent和RigidBodyComponent现在,这就是问题所在:我想要类似std::map的东西将组件类型和id映射到组件的位置。ids是将组件链接在一起的东西。我应该为此使用哪种容器?我不能使用std::map>自类型T取决于您用来为第一张map编制索引的类型索引。 最佳答案 您的用例听起来像是多态性的典型使用。您应该知道,任何在单个容器中存储“非同质”类型的尝试都会带来多态性的性能损失。至于您是使用C++提供的“开箱即用”多态性还是寻求自定义解决方案-这完全取决

c++ - STL 容器的右值引用限定符

为什么元素访问STL容器的成员函数,例如std::array::operator[]或std::vector::operator[]没有右值引用限定符重载?我当然可以做到std::move(generate_vector()[10]),但我很好奇在标准化引用限定符时是否考虑添加右值引用限定符重载。我认为std::array和std::tuple实际上是同一件事,后者的“元素访问函数(即std::get)”对于const与非const以及左值与右值的所有组合都重载了。为什么不是前者?将右值引用限定的元素访问成员函数(返回右值引用)添加到我的自定义容器是个好主意吗?编辑RichardCri

c++ - 我如何获得 xPy 的所有排列?

我想计算一组大小为X的大小为Y的所有排列。也就是说,如果我有(1,2,3)并且想要大小为2、3P2的所有排列,它将是(1,2)(1,3)(2,1)(2,3)(3,1)(3,2).GSL和C++STL都只提供我能看到的xPx。有人可以指出可以执行此操作的C/C++库或拼出一种快速且内存高效的算法吗?我正在尝试破解一个非常短的密码。我已经找出两个字母并决定进行暴力攻击。我有“ouglgouyakl”并且正在根据一本非常好的字典检查每个排列。我已经消除了2个字母,所以它的24P7或1,744,364,160种可能性还不错。我现在有一个Perl程序正在运行,所以这将是对编程时间+运行时间的总效